/* ============================================================
   Whiterock Road — homepage layout
   Builds on the design-system tokens + component classes.
   Limestone by default; [data-brand] reskins for free.
   ============================================================ */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body { margin: 0; background: var(--surface-page); overflow-x: hidden; }

.wr-site { min-height: 100vh; display: flex; flex-direction: column; }
.wr-container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--space-6); }
.wr-container--text { max-width: var(--container-text); }

/* ---------- Header ---------- */
.wr-header {
  position: sticky; top: 0; z-index: var(--z-sticky);
  background: color-mix(in srgb, var(--surface-page) 86%, transparent);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-subtle);
}
.wr-header__row { display: flex; align-items: center; justify-content: space-between; height: 74px; gap: var(--space-5); }
.wr-logo { display: inline-flex; align-items: center; gap: var(--space-3); color: var(--text-primary); text-decoration: none; }
.wr-logo svg { display: block; }
.wr-logo__wm { font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-medium); letter-spacing: -0.01em; white-space: nowrap; }
.wr-nav { display: flex; align-items: center; gap: var(--space-6); }
.wr-nav a { font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text-secondary); text-decoration: none; padding: 6px 2px; position: relative; white-space: nowrap; }
.wr-nav a:hover { color: var(--text-primary); }
.wr-header__cta { display: flex; align-items: center; gap: var(--space-3); }
.wr-burger { display: none; align-items: center; justify-content: center; background: none; border: 0; cursor: pointer; color: var(--text-primary); padding: 10px; margin-right: -10px; border-radius: var(--radius-sm); }
.wr-burger:hover { background: var(--surface-sunken); }

/* ---------- Buttons (compose with .wr-btn from components.css) ---------- */
.wr-btn__icon { width: 1.05em; height: 1.05em; flex: none; transition: transform var(--dur-base) var(--ease-out); }
.wr-btn:hover .wr-btn__icon { transform: translateX(2px); }

/* ---------- Section rhythm ---------- */
.wr-section { padding: var(--space-9) 0; }
.wr-section--tight { padding: var(--space-8) 0; }
.wr-section--sunken { background: var(--surface-sunken); }
.wr-section--ink { background: var(--surface-inverse); color: var(--text-inverse); --mark: var(--stone-300); }
.wr-section--ink .wr-h2, .wr-section--ink h3 { color: var(--text-inverse); }
.wr-section--ink .wr-lead { color: var(--stone-300); }
/* closing CTA flows straight into the dark footer — trim its bottom so the two dark blocks don't double up padding */
main > section.wr-section--ink:last-child { padding-bottom: var(--space-7); }

/* ---------- FAQ (no-JS accordion, doubles as AEO surface) ---------- */
.wr-faq { max-width: 860px; margin-top: var(--space-7); border-top: 1px solid var(--border-default); }
.wr-faq__item { border-bottom: 1px solid var(--border-default); }
.wr-faq__item summary { list-style: none; cursor: pointer; display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-5); padding: var(--space-5) 0; }
.wr-faq__item summary::-webkit-details-marker { display: none; }
.wr-faq__q { font-family: var(--font-display); font-size: var(--fs-lg); letter-spacing: -0.01em; line-height: 1.25; color: var(--text-primary); }
.wr-faq__item summary:hover .wr-faq__q { color: var(--text-accent); }
.wr-faq__ind { position: relative; flex: none; width: 16px; height: 16px; margin-top: 0.4em; }
.wr-faq__ind::before, .wr-faq__ind::after { content: ""; position: absolute; background: var(--accent); }
.wr-faq__ind::before { left: 0; top: 7px; width: 16px; height: 2px; }
.wr-faq__ind::after { left: 7px; top: 0; width: 2px; height: 16px; transition: transform 0.2s ease; }
.wr-faq__item[open] .wr-faq__ind::after { transform: scaleY(0); }
.wr-faq__a { margin: 0; padding: 0 0 var(--space-5); font-size: var(--fs-md); line-height: var(--lh-relaxed); color: var(--text-secondary); max-width: 70ch; }

.wr-eyebrow--mark { display: inline-flex; align-items: flex-start; gap: var(--space-2); }
.wr-eyebrow--mark::before { content: ""; width: 16px; height: 1.5px; background: var(--mark); opacity: 1; margin-top: calc(0.825em - 0.75px); }
.wr-kicker { display: inline-flex; margin-bottom: var(--space-4); }

.wr-h2 { font-size: clamp(2rem, 3.6vw, var(--fs-3xl)); margin: 0 0 var(--space-4); letter-spacing: -0.02em; }
.wr-lead { font-size: var(--fs-lg); color: var(--text-secondary); max-width: 56ch; line-height: var(--lh-relaxed); margin: 0; }
.wr-section-head { max-width: 64ch; margin-bottom: var(--space-7); }
.wr-section-head .wr-lead { margin-top: var(--space-4); }

/* ---------- Hero ---------- */
.wr-hero { padding: clamp(var(--space-8), 9vw, var(--space-10)) 0 var(--space-9); position: relative; }
.wr-hero__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-8); align-items: center; }
.wr-hero h1 {
  font-size: clamp(2.85rem, 6.2vw, 5.25rem);
  line-height: 1.0; letter-spacing: -0.03em;
  margin: var(--space-5) 0 var(--space-5); max-width: 15ch;
}
.wr-hero h1 em { font-style: italic; color: var(--text-accent); }
.wr-hero__lead { font-size: var(--fs-lg); color: var(--text-secondary); max-width: 50ch; line-height: var(--lh-relaxed); margin: 0 0 var(--space-6); }
.wr-hero__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: center; }
.wr-hero__meta { margin-top: var(--space-7); display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-5); align-items: center; font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
.wr-hero__meta span { display: inline-flex; align-items: flex-start; gap: var(--space-2); }
.wr-hero__meta span::before { content: ""; width: 5px; height: 5px; transform: rotate(45deg); background: var(--accent); flex: none; margin-top: calc(0.825em - 2.5px); }
.wr-hero__media { position: relative; }
.wr-hero__media image-slot { width: 100%; aspect-ratio: 4 / 5; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.wr-hero__diamond { position: absolute; right: -10px; bottom: -10px; }

/* hero variant: split (image right) */
.wr-hero--split .wr-hero__grid { grid-template-columns: 1.05fr 0.95fr; }

/* ---------- Stat / proof band ---------- */
.wr-proof { border-top: 1px solid var(--border-subtle); border-bottom: 1px solid var(--border-subtle); }
.wr-proof__grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.wr-stat { padding: var(--space-7) var(--space-6); border-right: 1px solid var(--border-subtle); }
.wr-stat:last-child { border-right: none; }
.wr-stat__num { font-family: var(--font-display); font-size: clamp(2.5rem, 4.5vw, var(--fs-4xl)); font-weight: var(--fw-medium); color: var(--text-accent); line-height: 1; letter-spacing: -0.02em; margin-bottom: var(--space-3); }
.wr-stat__label { font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-normal); max-width: 28ch; }

/* ---------- Generic grids ---------- */
.wr-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.wr-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }

/* ---------- Position cards ---------- */
.wr-position { display: flex; flex-direction: column; gap: var(--space-2); }
.wr-position__not { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); text-decoration: line-through; text-decoration-color: var(--border-strong); }
.wr-position h3 { font-size: var(--fs-xl); margin: var(--space-2) 0 var(--space-3); }
.wr-position p { font-size: var(--fs-base); color: var(--text-secondary); margin: 0; line-height: var(--lh-normal); }

/* ---------- Method (build · teach · coach) ---------- */
.wr-method { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); margin-top: var(--space-7); }
.wr-method__step { position: relative; padding-top: var(--space-5); border-top: 1.5px solid var(--border-default); }
.wr-method__n { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.06em; color: var(--mark); }
.wr-method__verb { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-medium); margin: var(--space-3) 0 var(--space-2); letter-spacing: -0.01em; }
.wr-method__when { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); margin-bottom: var(--space-3); }
.wr-method__step p { font-size: var(--fs-base); color: var(--text-secondary); margin: 0; line-height: var(--lh-normal); }

/* ---------- Offers ---------- */
.wr-offer__name { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); margin-bottom: var(--space-3); }
.wr-offer__title { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-medium); letter-spacing: var(--tracking-snug); margin: 0 0 var(--space-3); color: var(--text-primary); }
.wr-offer__desc { font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-relaxed); margin: 0 0 var(--space-5); }
.wr-offer__list { list-style: none; padding: 0; margin: 0 0 var(--space-6); display: flex; flex-direction: column; gap: var(--space-3); }
.wr-offer__list li { display: flex; gap: var(--space-3); font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-normal); }
.wr-offer__list li::before { content: ""; flex: none; width: 7px; height: 7px; margin-top: 0.5em; transform: rotate(45deg); border: 1.5px solid var(--mark); }
.wr-offer__foot { margin-top: auto; }
.wr-offer__out { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-tertiary); margin-bottom: var(--space-3); }

/* secondary-tier engagement list */
.wr-engagements { border-top: 1px solid var(--border-default); margin-top: var(--space-2); }
.wr-eng { display: grid; grid-template-columns: 0.8fr 1.6fr auto; gap: var(--space-5); align-items: baseline; padding: var(--space-5) 0; border-bottom: 1px solid var(--border-subtle); }
.wr-eng__name { font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-medium); color: var(--text-primary); }
.wr-eng__desc { font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-normal); margin: 0; }
.wr-eng__fmt { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); white-space: nowrap; justify-self: end; }

/* ---------- Story ---------- */
.wr-story-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: var(--space-8); align-items: start; }
.wr-story-grid image-slot { width: 100%; aspect-ratio: 4 / 5; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.wr-story p { font-size: var(--fs-lg); line-height: var(--lh-relaxed); color: var(--text-secondary); margin: 0 0 var(--space-5); max-width: 54ch; }
.wr-story p strong { color: var(--text-primary); font-weight: var(--fw-semibold); }
.wr-pull { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, var(--fs-2xl)); font-weight: var(--fw-medium); font-style: italic; letter-spacing: -0.015em; line-height: 1.25; color: var(--text-primary); margin: var(--space-6) 0; padding-left: var(--space-5); border-left: 2px solid var(--border-accent); max-width: 40ch; }
.wr-pull:last-child { margin-bottom: 0; }

/* ---------- Phrases ---------- */
.wr-phrases { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.wr-tag { display: inline-flex; align-items: center; font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text-secondary); background: var(--surface-card); border: 1px solid var(--border-default); padding: 0.375rem 0.875rem; border-radius: var(--radius-pill); }

/* ---------- Credibility strip ---------- */
.wr-cred { display: flex; align-items: center; gap: var(--space-5) var(--space-7); flex-wrap: wrap; }
.wr-cred__label { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
.wr-cred__names { display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-6); font-family: var(--font-display); font-size: var(--fs-lg); color: var(--text-secondary); }
.wr-cred__names span { white-space: nowrap; }

.wr-story__sub { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); display: block; margin: var(--space-7) 0 var(--space-3); }
.wr-story__sub:first-child { margin-top: 0; }

/* ---------- What I build (pills) ---------- */
.wr-build { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-7); align-items: start; }
.wr-build__col p { color: var(--text-secondary); line-height: var(--lh-relaxed); margin: 0 0 var(--space-4); }
.wr-build__col p strong { color: var(--text-primary); font-weight: var(--fw-semibold); }
.wr-divider-label { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); border-left: 2px solid var(--border-accent); padding-left: var(--space-3); margin: var(--space-5) 0 var(--space-3); }
.wr-pills { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.wr-pill { font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text-secondary); background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-pill); padding: 0.375rem 0.875rem; white-space: nowrap; }
.wr-tier-head { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: var(--space-4); margin-bottom: var(--space-6); }
.wr-tier-head .wr-h2 { margin: 0; }
.wr-tier-note { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
@media (max-width: 820px) { .wr-build { grid-template-columns: 1fr; gap: var(--space-6); } }

/* ---------- Four moves (one-size-fits-one grounding) ---------- */
.wr-moves { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); margin-top: var(--space-7); }
.wr-moves--3 { grid-template-columns: repeat(3, 1fr); }
.wr-move { padding: var(--space-5); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); background: var(--surface-card); box-shadow: var(--shadow-xs); }
.wr-move__n { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--mark); letter-spacing: 0.06em; }
.wr-move h4 { margin: var(--space-3) 0 var(--space-2); font-size: var(--fs-lg); }
.wr-move p { font-size: var(--fs-sm); color: var(--text-secondary); margin: 0; line-height: var(--lh-normal); }

/* ---------- Principles ---------- */
.wr-principles { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6) var(--space-8); margin-top: var(--space-7); }
.wr-principle { border-top: 1.5px solid var(--border-default); padding-top: var(--space-4); }
.wr-principle__n { font-family: var(--font-mono); font-size: var(--fs-2xs); color: var(--text-tertiary); letter-spacing: var(--tracking-label); }
.wr-principle h4 { margin: var(--space-2) 0 var(--space-2); font-size: var(--fs-xl); }
.wr-principle p { margin: 0; font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-normal); max-width: 46ch; }

/* ---------- Page hero (inner pages) ---------- */
.wr-pagehero { padding: clamp(var(--space-8), 7vw, var(--space-9)) 0 var(--space-8); }
.wr-pagehero h1 { font-size: clamp(2.5rem, 5.2vw, 4.25rem); line-height: 1.02; letter-spacing: -0.03em; margin: var(--space-5) 0 var(--space-5); max-width: 18ch; }
.wr-pagehero h1 em { font-style: italic; color: var(--text-accent); }
.wr-pagehero__lead { font-size: var(--fs-lg); color: var(--text-secondary); max-width: 56ch; line-height: var(--lh-relaxed); margin: 0; }

/* ---------- Two-up diamond cards ---------- */
.wr-diamond-card h3 { font-family: var(--font-display); font-size: var(--fs-2xl); margin: var(--space-4) 0 var(--space-3); }
.wr-diamond-card p { margin: 0; color: var(--text-secondary); line-height: var(--lh-relaxed); }

/* ---------- Before/after promise ---------- */
.wr-promise { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--space-7); align-items: center; }
.wr-promise__ba { display: flex; flex-direction: column; gap: var(--space-4); }
.wr-promise__chip { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--accent-soft); }

@media (max-width: 960px) { .wr-moves { grid-template-columns: 1fr 1fr; } .wr-promise { grid-template-columns: 1fr; } }
@media (max-width: 640px) { .wr-moves, .wr-principles { grid-template-columns: 1fr; } }

/* ---------- Core offering blocks (Coach · Teach · Build · Speak) ---------- */
.wr-offering { padding: var(--space-8) 0; border-top: 1px solid var(--border-subtle); }
.wr-offering:first-of-type { border-top: 0; }
.wr-offering-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; margin-bottom: var(--space-6); }
.wr-offering-head__name { display: inline-flex; align-items: baseline; gap: var(--space-3); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); }
.wr-offering-head__name b { font-weight: var(--fw-medium); color: var(--text-tertiary); }
.wr-offering-head__fmt { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
.wr-offering__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-7); align-items: start; }
.wr-offering__title { font-family: var(--font-display); font-size: clamp(1.875rem, 3.2vw, var(--fs-3xl)); font-weight: var(--fw-medium); letter-spacing: -0.02em; margin: 0 0 var(--space-4); }
/* Build page: path titles lead the hierarchy (above flywheel/shelf section h2s) */
#org .wr-offering__title, #expert .wr-offering__title { font-size: clamp(2.25rem, 4.4vw, var(--fs-4xl)); }
.wr-offering__title em { font-style: italic; color: var(--text-accent); }
.wr-offering__lead { font-size: var(--fs-lg); color: var(--text-secondary); line-height: var(--lh-relaxed); margin: 0 0 var(--space-5); max-width: 48ch; }
.wr-offering__note { font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-relaxed); margin: 0; }
.wr-offering__note strong { color: var(--text-primary); font-weight: var(--fw-semibold); }
.wr-offering__aside { display: flex; flex-direction: column; gap: var(--space-5); }
/* primary CTA in an offering aside sizes to its content, not the full column */
.wr-offering__aside .wr-btn { align-self: flex-start; }

/* build flow: map -> build -> retain */
.wr-flow { display: grid; grid-template-columns: 1fr; gap: var(--space-3); }
.wr-flow__step { display: grid; grid-template-columns: auto 1fr; gap: var(--space-4); align-items: start; padding: var(--space-4) var(--space-5); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); background: var(--surface-card); }
.wr-flow__k { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); white-space: nowrap; padding-top: 0.2em; }
.wr-flow__step h4 { font-size: var(--fs-md); margin: 0 0 2px; }
.wr-flow__step p { font-size: var(--fs-sm); color: var(--text-secondary); margin: 0; line-height: var(--lh-normal); }

/* speaking logo wall */
.wr-logos { display: flex; flex-wrap: wrap; gap: var(--space-4) var(--space-7); align-items: center; }
.wr-logos span { font-family: var(--font-display); font-size: var(--fs-xl); color: var(--text-tertiary); letter-spacing: -0.01em; white-space: nowrap; }

/* ---------- Listen / podcasts (Speak page) ---------- */
.wr-listen-head { max-width: 64ch; margin: var(--space-9) 0 var(--space-5); }
.wr-listen-head .wr-h2 { margin: var(--space-4) 0 var(--space-3); }
.wr-listen { display: flex; flex-direction: column; gap: var(--space-3); }
.wr-listen__item { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-4) var(--space-5); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); background: var(--surface-card); text-decoration: none; color: inherit; transition: border-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out); }
.wr-listen__item:hover { color: inherit; border-color: var(--border-accent); transform: translateX(3px); }
.wr-listen__item--feature { border-color: var(--border-accent); box-shadow: var(--shadow-sm); padding: var(--space-5); }
.wr-listen__mark { flex: none; width: 14px; height: 14px; transform: rotate(45deg); background: var(--mark); border-radius: 2px; }
.wr-listen__body { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.wr-listen__kind { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); }
.wr-listen__name { font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-medium); color: var(--text-primary); letter-spacing: -0.01em; }
.wr-listen__host { font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-normal); }
.wr-listen__arr { flex: none; color: var(--text-tertiary); width: 1.15em; height: 1.15em; }
.wr-listen__item:hover .wr-listen__arr { color: var(--text-accent); transform: translateX(2px); }

/* Where it started — the origin story gets room to breathe and a touch more weight */
#started p.wr-lead { margin-bottom: var(--space-6); }
#started .wr-listen__item--feature { padding: var(--space-6); gap: var(--space-5); align-items: flex-start; }
#started .wr-listen__mark { margin-top: 6px; }
#started .wr-listen__body { gap: var(--space-2); }
#started .wr-listen__name { font-size: var(--fs-xl); }
#started .wr-listen__arr { margin-top: 6px; }

@media (max-width: 820px) { .wr-offering__grid { grid-template-columns: 1fr; gap: var(--space-5); } }

/* ---------- Four-up offering teaser (home) ---------- */
.wr-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.wr-mini { display: flex; flex-direction: column; height: 100%; text-decoration: none; color: inherit; }
.wr-mini:hover { color: inherit; }
.wr-mini__name { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); margin-bottom: var(--space-3); }
.wr-mini h3 { font-size: var(--fs-xl); margin: 0 0 var(--space-2); }
.wr-mini p { font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-normal); margin: 0 0 var(--space-4); }
.wr-mini__foot { margin-top: auto; font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
@media (max-width: 900px) { .wr-grid-4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .wr-grid-4 { grid-template-columns: 1fr; } }

/* ---------- Contact ---------- */
.wr-cta-band { display: grid; grid-template-columns: 1.4fr auto; gap: var(--space-7); align-items: center; }
.wr-cta-band .wr-h2 { margin-bottom: var(--space-4); max-width: 22ch; }
.wr-cta-band .wr-lead { max-width: 48ch; }
@media (max-width: 820px) { .wr-cta-band { grid-template-columns: 1fr; gap: var(--space-5); } }

.wr-contact { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: start; }
.wr-form { display: flex; flex-direction: column; gap: var(--space-4); background: var(--surface-card); padding: var(--space-6); border-radius: var(--radius-lg); border: 1px solid var(--border-subtle); box-shadow: var(--shadow-sm); }
.wr-field { display: flex; flex-direction: column; gap: var(--space-2); }
.wr-label { font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--text-primary); }
.wr-help--error { font-size: var(--fs-sm); color: var(--danger); min-height: 1.1em; }

/* ---------- Evidence (Why now) ---------- */
.wr-ev { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-top: var(--space-7); }
.wr-ev__card { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-6); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); background: var(--surface-card); box-shadow: var(--shadow-xs); }
.wr-ev__num { font-family: var(--font-display); font-size: clamp(2.4rem, 3.8vw, var(--fs-4xl)); font-weight: var(--fw-medium); color: var(--text-accent); line-height: 1; letter-spacing: -0.02em; }
.wr-ev__claim { font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-normal); margin: 0; }
.wr-ev__src { margin-top: auto; padding-top: var(--space-3); border-top: 1px solid var(--border-subtle); font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
@media (max-width: 820px) { .wr-ev { grid-template-columns: 1fr; } }

/* big single evidence statement */
.wr-ev-pull { display: grid; grid-template-columns: 1.3fr 0.7fr; gap: var(--space-7); align-items: center; margin-top: var(--space-6); padding: var(--space-7); border: 1px solid var(--border-accent); border-radius: var(--radius-lg); background: var(--surface-card); box-shadow: var(--shadow-sm); }
.wr-ev-pull__q { font-family: var(--font-display); font-size: clamp(1.5rem, 2.6vw, var(--fs-2xl)); font-weight: var(--fw-medium); line-height: 1.28; letter-spacing: -0.015em; color: var(--text-primary); margin: 0; }
.wr-ev-pull__q em { font-style: italic; color: var(--text-accent); }
.wr-ev-pull__src { display: block; font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); margin-top: var(--space-4); }
.wr-ev-pull__big { font-family: var(--font-display); font-size: clamp(3rem, 6vw, 5rem); font-weight: var(--fw-medium); color: var(--text-accent); line-height: 0.95; letter-spacing: -0.03em; }
.wr-ev-pull__big small { display: block; font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-regular); color: var(--text-secondary); letter-spacing: 0; margin-top: var(--space-3); line-height: var(--lh-normal); }
@media (max-width: 820px) { .wr-ev-pull { grid-template-columns: 1fr; gap: var(--space-5); } }

/* boundary (ink) evidence list */
.wr-boundary { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: start; }
.wr-boundary__line { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-6); }
.wr-boundary__line span { display: flex; align-items: flex-start; gap: var(--space-3); font-family: var(--font-display); font-size: var(--fs-xl); color: var(--text-inverse); }
.wr-boundary__line span::before { content: ""; flex: none; width: 9px; height: 9px; margin-top: 0.5em; transform: rotate(45deg); background: var(--accent); }
.wr-boundary__ev { display: flex; flex-direction: column; gap: var(--space-5); }
.wr-boundary__fact { border-top: 1px solid color-mix(in srgb, var(--text-inverse) 18%, transparent); padding-top: var(--space-4); }
.wr-boundary__fact b { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-medium); color: var(--accent-soft); display: block; margin-bottom: var(--space-2); letter-spacing: -0.01em; }
.wr-boundary__fact p { margin: 0; color: var(--stone-300); font-size: var(--fs-base); line-height: var(--lh-normal); }
.wr-boundary__src { display: block; font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--stone-400); margin-top: var(--space-2); }
@media (max-width: 820px) { .wr-boundary { grid-template-columns: 1fr; gap: var(--space-6); } }

/* ---------- Testimonials ---------- */
.wr-quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); margin-top: var(--space-7); }
.wr-quote { display: flex; flex-direction: column; gap: var(--space-5); margin: 0; padding: var(--space-6); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); background: var(--surface-card); box-shadow: var(--shadow-xs); }
.wr-quote--feature { grid-column: 1 / -1; }
.wr-quote blockquote { margin: 0; }
.wr-quote__mark { flex: none; width: 15px; height: 15px; transform: rotate(45deg); background: var(--accent); border-radius: 2px; }
.wr-quote blockquote p { margin: 0; font-family: var(--font-display); font-size: var(--fs-lg); line-height: var(--lh-relaxed); color: var(--text-primary); font-weight: var(--fw-regular); }
.wr-quote--feature blockquote p { font-size: clamp(1.4rem, 2.4vw, var(--fs-2xl)); letter-spacing: -0.01em; line-height: 1.34; max-width: 30ch; }
.wr-quote__by { display: flex; align-items: center; gap: var(--space-3); margin-top: auto; }
.wr-quote__avatar { width: 46px; height: 46px; border-radius: 50%; flex: none; box-shadow: var(--shadow-xs); }
.wr-quote__meta { display: flex; flex-direction: column; gap: 2px; }
.wr-quote__name { font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--text-primary); }
.wr-quote__role { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
@media (max-width: 900px) { .wr-quotes { grid-template-columns: 1fr; } }

/* ---------- Epigraph (industry-voice quote) ---------- */
.wr-epigraph { max-width: 64ch; margin: 0 auto; text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-5); }
.wr-epigraph__mark { width: 18px; height: 18px; transform: rotate(45deg); background: var(--accent); border-radius: 3px; }
.wr-epigraph__q { margin: 0; font-family: var(--font-display); font-size: clamp(2rem, 4.4vw, 3.4rem); font-weight: var(--fw-medium); line-height: 1.14; letter-spacing: -0.02em; color: var(--text-inverse); max-width: 20ch; }
.wr-epigraph__by { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--accent-soft); }
.wr-epigraph__bridge { margin: var(--space-2) 0 0; font-size: var(--fs-lg); line-height: var(--lh-relaxed); color: var(--stone-300); max-width: 52ch; }

/* ---------- Record / archive (full appearances) ---------- */
.wr-rec { border-top: 1px solid var(--border-default); margin-top: var(--space-5); }
.wr-rec__item { display: grid; grid-template-columns: 12rem 1fr 7rem; gap: var(--space-3) var(--space-5); align-items: start; padding: var(--space-4) var(--space-3); border-bottom: 1px solid var(--border-subtle); text-decoration: none; color: inherit; border-radius: var(--radius-sm); transition: background var(--dur-base) var(--ease-out); }
a.wr-rec__item:hover { color: inherit; background: var(--surface-card); }
.wr-rec__src { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); padding-top: 3px; }
.wr-rec__body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.wr-rec__title { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-display); font-size: var(--fs-md); font-weight: var(--fw-medium); color: var(--text-primary); line-height: 1.25; }
.wr-rec__arr { width: 0.8em; height: 0.8em; flex: none; opacity: 0; transform: translate(-2px, 2px); transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out); color: var(--text-accent); }
a.wr-rec__item:hover .wr-rec__title { color: var(--text-accent); }
a.wr-rec__item:hover .wr-rec__arr { opacity: 1; transform: none; }
.wr-rec__note { font-size: var(--fs-sm); color: var(--text-secondary); line-height: var(--lh-normal); }
.wr-rec__meta { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); justify-self: end; white-space: nowrap; padding-top: 3px; }
.wr-rec__item--static { cursor: default; }
@media (max-width: 720px) {
  .wr-rec__item { grid-template-columns: 1fr; gap: 4px; padding: var(--space-4) var(--space-2); }
  .wr-rec__src { padding-top: 0; }
  .wr-rec__meta { justify-self: start; padding-top: 2px; }
  .wr-rec__arr { opacity: 1; transform: none; }
}

/* ---------- Real photography ---------- */
.wr-story-grid img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); display: block; }
.wr-evt { margin: var(--space-7) 0 0; }
.wr-evt img { width: 100%; max-height: 440px; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); display: block; }
.wr-evt figcaption { margin-top: var(--space-3); font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
@media (max-width: 960px) { .wr-story-grid img { aspect-ratio: 16 / 10; max-width: 460px; } }

/* event gallery (Speak) */
.wr-evt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); margin-top: var(--space-7); }
.wr-evt-grid img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--radius-md); box-shadow: var(--shadow-sm); display: block; }
.wr-evt-cap { margin-top: var(--space-3); font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
@media (max-width: 760px) { .wr-evt-grid { grid-template-columns: 1fr 1fr; } }

/* lens photo (Why) */
.wr-lens-head { display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--space-7); align-items: center; margin-bottom: var(--space-7); }
.wr-lens-photo { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; object-position: center 28%; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); display: block; }
@media (max-width: 820px) { .wr-lens-head { grid-template-columns: 1fr; gap: var(--space-5); } .wr-lens-photo { max-width: 460px; } }

/* ---------- Footer ---------- */
.wr-footer { margin-top: auto; background: var(--surface-inverse); color: var(--text-inverse); padding: var(--space-8) 0 var(--space-6); }
.wr-footer a { color: var(--stone-300); text-decoration: none; }
.wr-footer a:hover { color: var(--text-inverse); }
.wr-footer__row { display: flex; justify-content: space-between; gap: var(--space-7); flex-wrap: wrap; }
.wr-footer__brand { max-width: 30ch; }
.wr-footer__brand p { color: var(--stone-300); margin-top: var(--space-4); font-size: var(--fs-base); line-height: 1.6; }
.wr-footer__links { display: flex; gap: var(--space-8); flex-wrap: wrap; }
.wr-footer__col { display: flex; flex-direction: column; gap: var(--space-2); }
.wr-footer__col b { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--stone-400); margin-bottom: var(--space-1); font-weight: var(--fw-medium); }
.wr-footer__bottom { margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid color-mix(in srgb, var(--text-inverse) 16%, transparent); font-size: var(--fs-sm); color: var(--stone-400); display: flex; justify-content: space-between; gap: var(--space-4); flex-wrap: wrap; }
.wr-footer__bottom span:last-child { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; }

/* ---------- Quiet structural marks ----------
   Ordinals (01/02/03), eyebrow rules, and passive list diamonds use
   --mark (a quiet ink), NOT clay. This keeps CLAY reserved for actions,
   emphasis, wayfinding labels, and feature numbers — so it always means
   "look here." --mark flips light on .wr-section--ink (defined above). */

/* ---------- Entrance animation (gated, accessible) ----------
   Hidden state only applies when JS has added .js-anim to <html>,
   so a JS failure or no-JS context shows all content. */
@media (prefers-reduced-motion: no-preference) {
  .js-anim .wr-reveal { opacity: 0; transform: translateY(16px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out); }
  .js-anim .wr-reveal.is-in { opacity: 1; transform: none; }
}

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .wr-hero--split .wr-hero__grid { grid-template-columns: 1fr; }
  .wr-story-grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .wr-story-grid image-slot { aspect-ratio: 16 / 10; max-width: 460px; }
  .wr-hero__media { max-width: 460px; }
}
@media (max-width: 820px) {
  .wr-nav { display: none; }
  .wr-burger { display: inline-flex; }
  .wr-nav.wr-nav--open { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-2); position: absolute; top: 74px; left: 0; right: 0; background: var(--surface-page); border-bottom: 1px solid var(--border-subtle); padding: var(--space-4) var(--space-6); box-shadow: var(--shadow-md); }
  .wr-nav.wr-nav--open a { font-size: var(--fs-md); padding: var(--space-2) 0; }
  .wr-grid-3, .wr-grid-2, .wr-method, .wr-contact { grid-template-columns: 1fr; }
  .wr-proof__grid { grid-template-columns: 1fr; }
  .wr-stat { border-right: none; border-bottom: 1px solid var(--border-subtle); }
  .wr-stat:last-child { border-bottom: none; }
  .wr-eng { grid-template-columns: 1fr; gap: var(--space-2); }
  .wr-eng__fmt { justify-self: start; }
}
@media (max-width: 560px) {
  .wr-header__cta .wr-btn--primary { display: none; }
}

/* ============================================================
   BUILD PAGE — two paths fork, how-it-works, flywheel
   ============================================================ */

/* ---------- Fork: the two paths (Work teaser + Build hero) ---------- */
.wr-fork { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); margin-top: var(--space-7); }
.wr-fork--three { grid-template-columns: repeat(3, 1fr); }
.wr-fork__card {
  display: flex; flex-direction: column; gap: var(--space-3);
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); padding: var(--space-7);
  box-shadow: var(--shadow-sm); text-decoration: none; color: inherit;
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
a.wr-fork__card:hover { color: inherit; border-color: var(--border-accent); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.wr-fork__tag { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); }
.wr-fork__tag::before { content: ""; flex: none; width: 9px; height: 9px; transform: rotate(45deg); background: var(--accent); }
.wr-fork__card h3 { font-family: var(--font-display); font-size: clamp(1.6rem, 2.6vw, var(--fs-2xl)); font-weight: var(--fw-medium); letter-spacing: -0.015em; margin: var(--space-1) 0 0; }
.wr-fork__card h3 em { font-style: italic; color: var(--text-accent); }
.wr-fork__who { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
.wr-fork__card p { font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-relaxed); margin: 0; }
.wr-fork__go { margin-top: auto; padding-top: var(--space-4); display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--text-accent); }
a.wr-fork__card:hover .wr-fork__go .wr-btn__icon { transform: translateX(3px); }
@media (max-width: 980px) { .wr-fork--three { grid-template-columns: 1fr; } }
@media (max-width: 820px) { .wr-fork { grid-template-columns: 1fr; } }

/* ---------- How it works: numbered steps ---------- */
.wr-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); margin-top: var(--space-7); }
.wr-step { position: relative; padding-top: var(--space-5); border-top: 1.5px solid var(--border-default); }
.wr-step__n { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.06em; color: var(--mark); }
.wr-step h4 { font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-medium); margin: var(--space-3) 0 var(--space-2); letter-spacing: -0.01em; }
.wr-step p { font-size: var(--fs-sm); color: var(--text-secondary); margin: 0; line-height: var(--lh-normal); }
@media (max-width: 900px) { .wr-steps { grid-template-columns: 1fr 1fr; gap: var(--space-6); } }
@media (max-width: 520px) { .wr-steps { grid-template-columns: 1fr; } }

/* ---------- Pattern list (Path A example agents) ---------- */
.wr-patterns { display: flex; flex-direction: column; margin-top: var(--space-5); border-top: 1px solid var(--border-default); }
.wr-pattern { display: grid; grid-template-columns: auto 1fr; gap: var(--space-4) var(--space-5); align-items: baseline; padding: var(--space-5) 0; border-bottom: 1px solid var(--border-subtle); }
.wr-pattern__name { font-family: var(--font-display); font-size: var(--fs-xl); font-weight: var(--fw-medium); color: var(--text-primary); letter-spacing: -0.01em; }
.wr-pattern__desc { font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-normal); margin: 0; max-width: 60ch; }
@media (max-width: 640px) { .wr-pattern { grid-template-columns: 1fr; gap: var(--space-2); } }

/* ---------- Flywheel / cycle (Path B: the work is the marketing) ---------- */
.wr-flywheel { margin-top: var(--space-7); }
.wr-cycle { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); position: relative; }
.wr-cycle__step { position: relative; display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-5); background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); box-shadow: var(--shadow-xs); }
.wr-cycle__n { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; transform: rotate(45deg); border: 1.5px solid var(--mark); border-radius: var(--radius-xs); flex: none; }
.wr-cycle__n span { transform: rotate(-45deg); font-family: var(--font-mono); font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--mark); }
.wr-cycle__step h4 { font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-medium); margin: 0; letter-spacing: -0.01em; line-height: var(--lh-snug); }
.wr-cycle__step p { font-size: var(--fs-sm); color: var(--text-secondary); margin: 0; margin-top: auto; line-height: var(--lh-normal); }
.wr-cycle__step::after {
  content: ""; position: absolute; top: calc(var(--space-5) + 9px); right: calc(var(--space-5) * -0.5 - 5px);
  width: 11px; height: 11px; border-top: 1.5px solid var(--border-accent); border-right: 1.5px solid var(--border-accent);
  transform: rotate(45deg); z-index: 1;
}
.wr-cycle__step:last-child::after { display: none; }
.wr-cycle__loop { margin-top: var(--space-5); display: flex; align-items: center; gap: var(--space-3); font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
.wr-cycle__loop svg { width: 1.4em; height: 1.4em; color: var(--text-accent); flex: none; }
@media (max-width: 900px) { .wr-cycle { grid-template-columns: 1fr 1fr; } .wr-cycle__step:nth-child(2)::after { display: none; } }
@media (max-width: 520px) { .wr-cycle { grid-template-columns: 1fr; } .wr-cycle__step::after { display: none; } }

/* ---------- The "Built by JCK" mark — concrete artifact ---------- */
.wr-mark-demo {
  margin-top: var(--space-6); display: inline-flex; align-items: center; gap: var(--space-4);
  background: var(--surface-inverse); color: var(--text-inverse);
  border-radius: var(--radius-pill); padding: var(--space-3) var(--space-3) var(--space-3) var(--space-5);
  box-shadow: var(--shadow-md); max-width: 100%; flex-wrap: wrap;
}
.wr-mark-demo__sig { display: inline-flex; align-items: center; gap: var(--space-3); }
.wr-mark-demo__dot { width: 12px; height: 12px; transform: rotate(45deg); background: var(--accent); border-radius: 2px; flex: none; }
.wr-mark-demo__txt { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--stone-300); }
.wr-mark-demo__txt b { color: var(--text-inverse); font-weight: var(--fw-medium); }
.wr-mark-demo__cta { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--accent-contrast); background: var(--accent); border-radius: var(--radius-pill); padding: 0.4rem 0.9rem; text-decoration: none; white-space: nowrap; }
.wr-mark-demo__cta:hover { background: var(--accent-hover); color: var(--accent-contrast); }
.wr-mark-demo__cta .wr-btn__icon { width: 1em; height: 1em; }

/* ---------- The shelf (Path B: repeatable-architecture discount) ---------- */
.wr-shelf { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: var(--space-7); align-items: start; margin-top: var(--space-8); padding: var(--space-7); background: var(--surface-card); border: 1px solid var(--border-accent); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.wr-shelf__body .wr-kicker { margin-bottom: var(--space-3); }
.wr-shelf__body h3 { font-family: var(--font-display); font-size: clamp(1.5rem, 2.6vw, var(--fs-2xl)); font-weight: var(--fw-medium); letter-spacing: -0.015em; margin: 0 0 var(--space-3); line-height: var(--lh-snug); }
.wr-shelf__body h3 em { font-style: italic; color: var(--text-accent); }
.wr-shelf__body p { font-size: var(--fs-base); color: var(--text-secondary); line-height: var(--lh-relaxed); margin: 0 0 var(--space-3); max-width: 54ch; }
.wr-shelf__body p:last-child { margin-bottom: 0; }
.wr-shelf__body p strong { color: var(--text-primary); font-weight: var(--fw-semibold); }
.wr-shelf__rack { background: var(--surface-sunken); border-radius: var(--radius-md); padding: var(--space-5); }
.wr-shelf__rack-label { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-tertiary); }
.wr-shelf__items { display: flex; flex-direction: column; gap: var(--space-2); margin: var(--space-4) 0; }
.wr-shelf__item { display: flex; align-items: center; gap: var(--space-3); font-family: var(--font-sans); font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text-primary); background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-sm); padding: 0.55rem 0.85rem; box-shadow: var(--shadow-xs); }
.wr-shelf__item::before { content: ""; flex: none; width: 8px; height: 8px; transform: rotate(45deg); background: var(--accent); }
.wr-shelf__item--ghost { color: var(--text-tertiary); border-style: dashed; background: transparent; box-shadow: none; }
.wr-shelf__item--ghost::before { background: var(--border-strong); }
.wr-shelf__flow { font-family: var(--font-mono); font-size: var(--fs-2xs); letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--text-accent); line-height: var(--lh-relaxed); }
@media (max-width: 820px) { .wr-shelf { grid-template-columns: 1fr; gap: var(--space-5); padding: var(--space-6); } }
